home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c11 / ShowMethodsClean.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.9 KB  |  138 lines

  1. //: ShowMethodsClean.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // ShowMethods with the qualifiers stripped
  50. // to make the results easier to read
  51. import java.lang.reflect.*;
  52. import java.io.*;
  53.  
  54. public class ShowMethodsClean {
  55.   static final String usage =
  56.     "usage: \n" +
  57.     "ShowMethodsClean qualified.class.name\n" +
  58.     "To show all methods in class or: \n" +
  59.     "ShowMethodsClean qualif.class.name word\n" +
  60.     "To search for methods involving 'word'";
  61.   public static void main(String[] args) {
  62.     if(args.length < 1) {
  63.       System.out.println(usage);
  64.       System.exit(0);
  65.     }
  66.     try {
  67.       Class c = Class.forName(args[0]);
  68.       Method[] m = c.getMethods();
  69.       Constructor[] ctor = c.getConstructors();
  70.       // Convert to an array of cleaned Strings:
  71.       String[] n = 
  72.         new String[m.length + ctor.length];
  73.       for(int i = 0; i < m.length; i++) {
  74.         String s = m[i].toString();
  75.         n[i] = StripQualifiers.strip(s);
  76.       }
  77.       for(int i = 0; i < ctor.length; i++) {
  78.         String s = ctor[i].toString();
  79.         n[i + m.length] = 
  80.           StripQualifiers.strip(s);
  81.       }
  82.       if(args.length == 1)
  83.         for (int i = 0; i < n.length; i++)
  84.           System.out.println(n[i]);
  85.       else
  86.         for (int i = 0; i < n.length; i++)
  87.           if(n[i].indexOf(args[1])!= -1)
  88.             System.out.println(n[i]);
  89.     } catch (ClassNotFoundException e) {
  90.       System.out.println("No such class: " + e);
  91.     }
  92.   }
  93. }
  94.  
  95. class StripQualifiers {
  96.   private StreamTokenizer st;
  97.   public StripQualifiers(String qualified) {
  98.       st = new StreamTokenizer(
  99.         new StringReader(qualified));
  100.       st.ordinaryChar(' '); // Keep the spaces
  101.   }
  102.   public String getNext() {
  103.     String s = null;
  104.     try {
  105.       if(st.nextToken() !=
  106.             StreamTokenizer.TT_EOF) {
  107.         switch(st.ttype) {
  108.           case StreamTokenizer.TT_EOL:
  109.             s = null;
  110.             break;
  111.           case StreamTokenizer.TT_NUMBER:
  112.             s = Double.toString(st.nval);
  113.             break;
  114.           case StreamTokenizer.TT_WORD:
  115.             s = new String(st.sval);
  116.             break;
  117.           default: // single character in ttype
  118.             s = String.valueOf((char)st.ttype);
  119.         }
  120.       }
  121.     } catch(IOException e) {
  122.       System.out.println(e);
  123.     }
  124.     return s;
  125.   }
  126.   public static String strip(String qualified) {
  127.     StripQualifiers sq = 
  128.       new StripQualifiers(qualified);
  129.     String s = "", si;
  130.     while((si = sq.getNext()) != null) {
  131.       int lastDot = si.lastIndexOf('.');
  132.       if(lastDot != -1)
  133.         si = si.substring(lastDot + 1);
  134.       s += si;
  135.     }
  136.     return s;
  137.   }
  138. } ///:~